| *Name:         |  |
|----------------|--|
|                |  |
| *Registration: |  |

Department of Computer Systems Engineering University of Engineering & Technology Peshawar

# Digital System Design CSE 308

## Midterm Examination Spring 2020

3 July 2020, Duration: 150 Minutes

Start Time: 2:30 P.M. (Sharp) End Time: 5:00 P.M. (Sharp)

#### \*\*Exam Rules\*\*

## Please read carefully before proceeding.

- 1- This exam is open books/notes/Internet.
- 2- It's good to share but sharing of books, notes, and other materials during this exam is not permitted.
- 3- Answer all problems.
- 4- Problems will not be interpreted during the exam.

## Problem 1. (25 pts.)

Below is an RTL (or Dataflow) description for a circuit.

```
module RTL_circuit (x, y, a, b, c);

parameter x_delay = 5, y_delay = 10;
input a, b, c;
output x, y;
wire a, b, c, x, y;
wire na, nb, nc, t3, t4, t5;

assign na = !a;
assign nb = !b;
assign nc = !c;
assign t3 = na && b && c;
assign t4 = a && nb && c;
assign t5 = a && b && nc;
assign #x_delay x = t3 || t5;
assign #y_delay y = a || t4;
```

1(a) (3 pts.) Give a Verilog statement that instantiates the above RTL\_circuit, with the instance name MID. When you instantiate the circuit, use the same names for wires as is used in the module port list.

#### Solution:

1(b) (6 pts.) Rewrite the RTL\_circuit using Verilog built-in primitives and structural Verilog. Your design should have the same overall delays (from module inputs to module outputs) as the original code. It is fine to let some gates have zero delay. Part of the module is done for you.

```
module struct_circuit (x, y, a, b, c);

parameter x_delay = 5, y_delay = 10;
input a, b, c;
output x, y;
//Write your code here

endmodule
```

| $\sim$ | -      |      | 100 |   |   |
|--------|--------|------|-----|---|---|
| $\sim$ | $\cap$ | 1 11 | + 1 | n | • |
|        |        |      |     |   |   |



1(c) (3 pts.) Draw a gate-level diagram for your module in 1(b). Label
 all nets on the diagram and write the delay of each gate inside the
 gate.

Solution:

1(d) (6 pts.) Rewrite the RTL\_circuit using behavioral Verilog. Your
 design should have the same delays as the original code. Part of the
 module is done for you.

```
module behav_circuit (x, y, a, b, c);

parameter x_delay = 5, y_delay = 10;
input a, b, c;
output x, y;
//Write your code here

endmodule
```

| Solution: |
|-----------|
|           |
|           |
|           |
|           |
|           |
|           |
|           |
|           |
|           |
|           |
|           |
|           |
|           |
|           |

1(e) (7 pts.) Write the output of RTL\_circuit for the following test bench.

```
//test bench for RTL circuit
module test RTL circuit;
     reg a, b, c;
    wire x, y;
    RTL circuit RTLC (x, y, a, b, c);
     Initial begin
          a = 1; b = 1; c = 1;
          #30 a = 0; b = 1; c = 1;
     end
     initial begin
          $display ($time, " x = b and y = b", x, y);
          #6 $display ($time, " x = %b and y = %b", x, y);
          #5 $display ($time, " x = %b and y = %b", x, y);
          #20 $display ($time, " x = %b and y = %b", x, y);
          #5 $display ($time, " x = %b and y = %b", x, y);
          #6 $display ($time, " x = %b and y = %b", x, y);
          #8 $display ($time, " x = %b and y = %b", x, y);
     end
endmodule
```

| $\sim$ | -      | 1     |               |     |       |  |
|--------|--------|-------|---------------|-----|-------|--|
| ς.     | $\sim$ | 1 1 7 | ı <del></del> |     | n     |  |
| . )    | ( )    | ι ι.  |               | ι . | , , , |  |

## Problem 2. (30 pts.)

2(a) (10 pts.) In this problem, design a 4-bit (Mod-8) Johnson counter (the circuit and state diagrams are given below).



The suggested skeleton file has been written below. The module has 2 inputs - CLK and CLR which is active low. The output is Q which is 4-bit in size.

```
module JS_counter (CLK, CLR, Q);
    input CLK, CLR;
    output [3:0] Q;
    //Place your code here

endmodule
```

| Solution: |  |
|-----------|--|
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |

2(b) (10 pts.) In this problem, design a 4-to-16 Decoder with Enable input (the block diagram is given below).



The suggested skeleton file has been written below. The module has 5 inputs - A, B, C, D and En which is active high. The output is 0 which is 16-bit in size.

```
module Dec_4x16 (A, B, C, D, En, O);
  input A, B, C, D, En; //Assume A is MSB and D is LSB
  output [15:0] O;
  //Place your code here

endmodule
```

| Solution: |  |
|-----------|--|
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |
|           |  |

2(c) (10 pts.) In this problem, combine the Johnson counter (from 2(a))
with the decoder (from 2(b)) to create a circuit such that the output
of the Johnson counter controls the data lines of the decoder. Assume
that the decoder is enabled (i.e. the En input is tied to VCC or 1).

The top-level design has the following port definitions:

| CLK      | 1-bit clock        |
|----------|--------------------|
| RESET    | 1-bit reset line   |
| OUT_DATA | 16-bit data output |

The suggested skeleton file has been written below.

```
module Top (CLK, RESET, OUT_DATA);
  input CLK, RESET;
  output [15:0] OUT_DATA;
  //Place your code here
endmodule
```

#### Solution: